CVE-2024-27414
rtnetlink: fix error logic of IFLA_BRIDGE_FLAGS writing back
Description
In the Linux kernel, the following vulnerability has been resolved: rtnetlink: fix error logic of IFLA_BRIDGE_FLAGS writing back In the commit d73ef2d69c0d ("rtnetlink: let rtnl_bridge_setlink checks IFLA_BRIDGE_MODE length"), an adjustment was made to the old loop logic in the function `rtnl_bridge_setlink` to enable the loop to also check the length of the IFLA_BRIDGE_MODE attribute. However, this adjustment removed the `break` statement and led to an error logic of the flags writing back at the end of this function. if (have_flags) memcpy(nla_data(attr), &flags, sizeof(flags)); // attr should point to IFLA_BRIDGE_FLAGS NLA !!! Before the mentioned commit, the `attr` is granted to be IFLA_BRIDGE_FLAGS. However, this is not necessarily true fow now as the updated loop will let the attr point to the last NLA, even an invalid NLA which could cause overflow writes. This patch introduces a new variable `br_flag` to save the NLA pointer that points to IFLA_BRIDGE_FLAGS and uses it to resolve the mentioned error logic.
INFO
Published Date :
May 17, 2024, 12:15 p.m.
Last Modified :
Nov. 21, 2024, 9:04 a.m.
Remotely Exploit :
No
Source :
416baaa9-dc9f-4396-8d5f-8c081fb06d67
Solution
- Update the affected kernel packages.
- Reboot the system after updating the kernel.
References to Advisories, Solutions, and Tools
                                            Here, you will find a curated list of external links that provide in-depth
                                            information, practical solutions, and valuable tools related to
                                            CVE-2024-27414.
                                        
CWE - Common Weakness Enumeration
            While CVE identifies
            specific instances of vulnerabilities, CWE categorizes the common flaws or
            weaknesses that can lead to vulnerabilities. CVE-2024-27414 is
            associated with the following CWEs:
        
Common Attack Pattern Enumeration and Classification (CAPEC)
Common Attack Pattern Enumeration and Classification
            (CAPEC)
            stores attack patterns, which are descriptions of the common attributes and
            approaches employed by adversaries to exploit the CVE-2024-27414
            weaknesses.
We scan GitHub repositories to detect new proof-of-concept exploits. Following list is a collection of public exploits and proof-of-concepts, which have been published on GitHub (sorted by the most recently updated).
Results are limited to the first 15 repositories due to potential performance issues.
			The following list is the news that have been mention
			CVE-2024-27414 vulnerability anywhere in the article.
		
                The following table lists the changes that have been made to the
                CVE-2024-27414 vulnerability over time.
            
Vulnerability history details can be useful for understanding the evolution of a vulnerability, and for identifying the most recent changes that may impact the vulnerability's severity, exploitability, or other characteristics.
- 
                            CVE Modified by af854a3a-2127-422b-91ae-364da2661108Nov. 21, 2024 Action Type Old Value New Value Added Reference https://git.kernel.org/stable/c/167d8642daa6a44b51de17f8ff0f584e1e762db7 Added Reference https://git.kernel.org/stable/c/743ad091fb46e622f1b690385bb15e3cd3daf874 Added Reference https://git.kernel.org/stable/c/831bc2728fb48a8957a824cba8c264b30dca1425 Added Reference https://git.kernel.org/stable/c/882a51a10ecf24ce135d573afa0872aef02c5125 Added Reference https://git.kernel.org/stable/c/a1227b27fcccc99dc44f912b479e01a17e2d7d31 Added Reference https://git.kernel.org/stable/c/b9fbc44159dfc3e9a7073032752d9e03f5194a6f Added Reference https://git.kernel.org/stable/c/f2261eb994aa5757c1da046b78e3229a3ece0ad9 Added Reference https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html 
- 
                            CVE Modified by 416baaa9-dc9f-4396-8d5f-8c081fb06d67Nov. 05, 2024 Action Type Old Value New Value Removed Reference kernel.org https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html 
- 
                            CVE Modified by 416baaa9-dc9f-4396-8d5f-8c081fb06d67Jun. 25, 2024 Action Type Old Value New Value Added Reference kernel.org https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html [No types assigned] 
- 
                            CVE Modified by 416baaa9-dc9f-4396-8d5f-8c081fb06d67May. 29, 2024 Action Type Old Value New Value 
- 
                            CVE Received by 416baaa9-dc9f-4396-8d5f-8c081fb06d67May. 17, 2024 Action Type Old Value New Value Added Description In the Linux kernel, the following vulnerability has been resolved: rtnetlink: fix error logic of IFLA_BRIDGE_FLAGS writing back In the commit d73ef2d69c0d ("rtnetlink: let rtnl_bridge_setlink checks IFLA_BRIDGE_MODE length"), an adjustment was made to the old loop logic in the function `rtnl_bridge_setlink` to enable the loop to also check the length of the IFLA_BRIDGE_MODE attribute. However, this adjustment removed the `break` statement and led to an error logic of the flags writing back at the end of this function. if (have_flags) memcpy(nla_data(attr), &flags, sizeof(flags)); // attr should point to IFLA_BRIDGE_FLAGS NLA !!! Before the mentioned commit, the `attr` is granted to be IFLA_BRIDGE_FLAGS. However, this is not necessarily true fow now as the updated loop will let the attr point to the last NLA, even an invalid NLA which could cause overflow writes. This patch introduces a new variable `br_flag` to save the NLA pointer that points to IFLA_BRIDGE_FLAGS and uses it to resolve the mentioned error logic. Added Reference kernel.org https://git.kernel.org/stable/c/b9fbc44159dfc3e9a7073032752d9e03f5194a6f [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/882a51a10ecf24ce135d573afa0872aef02c5125 [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/a1227b27fcccc99dc44f912b479e01a17e2d7d31 [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/f2261eb994aa5757c1da046b78e3229a3ece0ad9 [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/167d8642daa6a44b51de17f8ff0f584e1e762db7 [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/831bc2728fb48a8957a824cba8c264b30dca1425 [No types assigned] Added Reference kernel.org https://git.kernel.org/stable/c/743ad091fb46e622f1b690385bb15e3cd3daf874 [No types assigned] 
 
                         
                         
                         
                                             
                                            